<!DOCTYPE HTML>
<meta charset=utf8>
<title>Test for Element.closest</title>
<script src="../../resources/testharness.js"></script>
<script src="../../resources/testharnessreport.js"></script>
<body id="body">
  <div id="test8" class="div3" style="display:none">
    <div id="test7" class="div2">
      <div id="test6" class="div1">
        <form id="test10" class="form2"></form>
        <form id="test5" class="form1" name="form-a">
          <input id="test1" class="input1" required>
          <fieldset class="fieldset2" id="test2">
            <select id="test3" class="select1" required>
              <option default id="test4" value="">Test4</option>
              <option selected id="test11">Test11</option>
              <option id="test12">Test12</option>
              <option id="test13">Test13</option>
            </select>
            <input id="test9" type="text" required>
          </fieldset>
        </form>
      </div>
    </div>
  </div>
  <div id=log></div>
<script>
  do_test("select"                     , "test12", "test3");
  do_test("fieldset"                   , "test13", "test2");
  do_test("div"                        , "test13", "test6");
  do_test("body"                       , "test3" , "body");

  do_test("[default]"                  , "test4" , "test4");
  do_test("[selected]"                 , "test4" , "");
  do_test("[selected]"                 , "test11", "test11");
  do_test('[name="form-a"]'            , "test12", "test5");
  do_test('form[name="form-a"]'        , "test13", "test5");
  do_test("input[required]"            , "test9" , "test9");
  do_test("select[required]"           , "test9" , "");

  do_test("div:not(.div1)"             , "test13", "test7");
  do_test("div.div3"                   , "test6" , "test8");
  do_test("div#test7"                  , "test1" , "test7");

  do_test(".div3 > .div2"              , "test12", "test7");
  do_test(".div3 > .div1"              , "test12", "");
  do_test("form > input[required]"     , "test9" , "");
  do_test("fieldset > select[required]", "test12", "test3");

  do_test("input + fieldset"           , "test6" , "");
  do_test("form + form"                , "test3" , "test5");
  do_test("form + form"                , "test5" , "test5");

  do_test(":empty"                     , "test10", "test10");
  do_test(":last-child"                , "test11", "test2");
  do_test(":first-child"               , "test12", "test3");
  do_test(":invalid"                   , "test11", "test2");

  do_test(":scope"                     , "test4",  "test4");
  do_test("select > :scope"            , "test4",  "test4");
  do_test("div > :scope"               , "test4",  "");
  do_test(":has(> :scope)"             , "test4",  "test3");
function do_test(aSelector, aElementId, aTargetId) {
  test(function() {
    var el = document.getElementById(aElementId).closest(aSelector);
    if (el === null) {
      assert_equals("", aTargetId, aSelector);
    } else {
      assert_equals(el.id, aTargetId, aSelector);
    }
  }, "Element.closest with context node '" + aElementId + "' and selector '" + aSelector + "'");
}
</script>
